package com.sugar.queryinfo.module.business.service.tffinance;

import java.util.*;
import javax.validation.*;
import javax.validation.constraints.NotNull;

import com.sugar.queryinfo.module.business.controller.admin.tffinance.vo.*;
import com.sugar.queryinfo.module.business.dal.dataobject.tffinance.TfFinanceDO;
import com.sugar.queryinfo.framework.common.pojo.PageResult;
import com.sugar.queryinfo.framework.common.pojo.PageParam;
import com.sugar.queryinfo.module.infra.controller.admin.file.vo.file.FileUploadReqVO;

/**
 * 真假财务 Service 接口
 *
 * @author Ysugar
 */
public interface TfFinanceService {

    /**
     * 创建真假财务
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    Long createTfFinance(@Valid TfFinanceSaveReqVO createReqVO);

    /**
     * 更新真假财务
     *
     * @param updateReqVO 更新信息
     */
    void updateTfFinance(@Valid TfFinanceSaveReqVO updateReqVO);

    /**
     * 删除真假财务
     *
     * @param id 编号
     */
    void deleteTfFinance(Long id);

    /**
    * 批量删除真假财务
    *
    * @param ids 编号
    */
    void deleteTfFinanceListByIds(List<Long> ids);

    /**
     * 获得真假财务
     *
     * @param id 编号
     * @return 真假财务
     */
    TfFinanceDO getTfFinance(Long id);

    /**
     * 获得真假财务分页
     *
     * @param pageReqVO 分页查询
     * @return 真假财务分页
     */
    PageResult<TfFinanceDO> getTfFinancePage(TfFinancePageReqVO pageReqVO);

    List<TfFinanceRespVO> getTfFinancesByIds(List<Long> ids);

    void importExcel(FileUploadReqVO uploadReqVO);
}